// 导入数据库操作模块
const db = require("../db/index");
// 在头部区域导入 bcryptjs 后，
// 即可使用 bcrypt.compareSync(提交的密码，数据库中的密码) 方法验证密码是否正确
// compareSync() 函数的返回值为布尔值，true 表示密码正确，false 表示密码错误
const bcrypt = require("bcryptjs");

// 用户列表的处理函数
exports.getUserList = (req, res) => {
    // 根据用户的角色类型及用户名，查询所有用户信息
    // 注意：为了防止用户的密码泄露，需要排除 password 字段  like `+"'%"+"?"+"%'"
    const { role_type, username, pageNum, pageSize } = req.query;
    let sql =
        "select * from ev_users where is_delete=0";
    let otherSql = `select * from ev_users where is_delete=0`;
    if (username) {
        sql += ` and username like concat("%${username}%")`;
        otherSql += ` and username like concat("%${username}%")`;
    } else if (role_type) {
        sql += ` and role_type=${role_type}`;
        otherSql += ` and role_type=${role_type}`;
    }
    // sql 分页
    sql = sql + ` limit ${pageSize} offset ${pageSize * (pageNum - 1)}`;
    db.query(sql, (err, results1) => {
        // 1. 执行 SQL 语句失败
        if (err) return res.cc(err);
        // 2. 执行 SQL 语句成功，但是查询到的数据条数等于0
        if (results1.length === 0) return res.send({ status: 0, data: [], total: results1.length })
        db.query(otherSql, (err, results2) => {
            // 1. 执行 SQL 语句失败
            if (err) return res.cc(err);
            // 2. 执行 SQL 语句成功，但是查询到的数据条数等于0
            if (results2.length === 0) return res.send({ status: 0, data: [], total: results2.length })
            // 3. 将用户信息响应给客户端
            res.send({
                status: 0,
                message: "获取成功！",
                data: results1,
                total: results2.length
            });
        });
    });
};

// 获取用户基本信息的处理函数
exports.getUserInfo = (req, res) => {
    // 兼容 req.user 为空的情况，给出友好提示
    if (!req.user || !req.user.id) {
        return res.cc('无法获取用户身份信息，请重新登录！')
    }
    const sql = `select id, role_type, username, nickname, email from ev_users where id=?`;
    db.query(sql, req.user.id, (err, results) => {
        if (err) return res.cc(err);
        if (results.length !== 1) return res.cc("获取用户信息失败！");
        res.send({
            status: 0,
            message: "获取用户基本信息成功！",
            data: results[0],
        });
    });
};
// 更新用户基本信息的处理函数
exports.updateUserInfo = (req, res) => {
    const sql = `update ev_users set ? where id=?`;
    // 对新密码进行 bcrypt 加密处理
    const newPwd = bcrypt.hashSync(req.body.password, 10);
    db.query(sql, [{ ...req.body, password: newPwd }, req.body.id], (err, results) => {
        // 执行 SQL 语句失败
        if (err) return res.cc(err);

        // 执行 SQL 语句成功，但影响行数不为 1
        if (results.affectedRows !== 1) return res.cc("修改用户基本信息失败！");

        // 修改用户信息成功
        return res.cc("修改用户基本信息成功！", 0);
    });
};
// 删除用户
exports.deleteUser = (req, res) => {
    // 定义标记删除的 SQL 语句
    const sql = 'update ev_users set is_delete=1 where id=?'
    // 调用 db.query() 执行 SQL 语句
    db.query(sql, req.params.id, (err, results) => {
        if (err) return res.cc(err);
        if (results.affectedRows !== 1) return res.cc('删除失败！');
        res.cc('删除成功！', 0)
    })
}
// 重置密码的处理函数
exports.updatePassword = (req, res) => {
    // 定义根据 id 查询用户数据的 SQL 语句
    const sql = `select * from ev_users where id=?`;

    // 执行 SQL 语句查询用户是否存在
    db.query(sql, req.user.id, (err, results) => {
        // 执行 SQL 语句失败
        if (err) return res.cc(err);

        // 检查指定 id 的用户是否存在
        if (results.length !== 1) return res.cc("用户不存在！");

        // TODO：判断提交的旧密码是否正确
        // 判断提交的旧密码是否正确
        const compareResult = bcrypt.compareSync(
            req.body.oldPwd,
            results[0].password
        );
        if (!compareResult) return res.cc("旧密码错误！");
        // 定义更新用户密码的 SQL 语句
        const sql = `update ev_users set password=? where id=?`;

        // 对新密码进行 bcrypt 加密处理
        const newPwd = bcrypt.hashSync(req.body.newPwd, 10);

        // 执行 SQL 语句，根据 id 更新用户的密码
        db.query(sql, [newPwd, req.user.id], (err, results) => {
            // SQL 语句执行失败
            if (err) return res.cc(err);

            // SQL 语句执行成功，但是影响行数不等于 1
            if (results.affectedRows !== 1) return res.cc("更新密码失败！");

            // 更新密码成功
            res.cc("更新密码成功！", 0);
        });
    });
};
// 更新用户头像的处理函数
exports.updateAvatar = (req, res) => {
    // 定义更新用户头像的 SQL 语句：
    const sql = "update ev_users set user_pic=? where id=?";
    // 调用 db.query() 执行 SQL 语句，更新对应用户的头像：
    db.query(sql, [req.body.avatar, req.user.id], (err, results) => {
        // 执行 SQL 语句失败
        if (err) return res.cc(err);

        // 执行 SQL 语句成功，但是影响行数不等于 1
        if (results.affectedRows !== 1) return res.cc("更新头像失败！");

        // 更新用户头像成功
        return res.cc("更新头像成功！", 0);
    });
};
